/*
 * Login.java
 *
 * Questo esempio mostra come utilizzare le sessioni per autenticare un utente
 *
 */
package it.univaq.iw.jweb;

import it.univaq.iw.jweb.data.DataAccess;
import it.univaq.iw.jweb.data.Utente;
import it.univaq.iw.jweb.utils.ControlsHelpers;

import it.univaq.iw.jweb.utils.TemplateManager;
import java.io.*;

import java.util.Calendar;
import java.util.Map;
import javax.servlet.*;
import javax.servlet.http.*;

/**
 *
 * @author Ingegneria del Web
 * @version
 */
public class Login extends HttpServlet {

    private DataAccess da;
    private TemplateManager tpl;

    @Override
    public void init(ServletConfig config) throws ServletException {
        super.init(config);
        
        da = DataAccess.getInstance();

        tpl = TemplateManager.getInstance(getServletContext());
        tpl.setOutlineTemplate("outline");
        tpl.setDefaultData("author", "Del Vecchio - Bevini - Delfino");
        tpl.setDefaultData("homepage_url", "home");
        tpl.setDefaultData("logged", false);

    }

    /** Processes requests for both HTTP <code>GET</code> and <code>POST</code> methods.
     * @param request servlet request
     * @param response servlet response
     */
    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        HttpSession s = request.getSession(true);
        PrintWriter out = response.getWriter();

        Map datamodel = tpl.getDefaultDataModel();

        String email = request.getParameter("email");
        String password = request.getParameter("pass");

        if (!password.isEmpty() && !email.isEmpty()) {
            if (ControlsHelpers.controllaMail(email)) { /* le credenziali inserite sono inserite correttamente */

                Utente user = da.searchUtente(new Utente(email,password));

                if (user != null) { /* le credenziali sono giuste valide - utente - riconosciuto */

                    s.setAttribute("email", email);
                    s.setAttribute("ip", request.getRemoteHost());
                    s.setAttribute("inizio-sessione", Calendar.getInstance());
                    s.setAttribute("userid", 1);

                    response.sendRedirect("home");

                } else {

                    /* la mail inserita è corretta ma le credenziali sono o sbagliate o sono ancora da accreditare "azienda" */

                    String nomeGruppo = da.searchNomeGruppo(email);
                    if (nomeGruppo != null) {

                        datamodel.put("errore", "ATTENZIONE! Come azienda registrata devi attendere l'accredito da parte dell'amministratore del sito.");
                        tpl.process("home", datamodel, out);
                        out.close();
                        return;

                    } else {

                        datamodel.put("errore", "ATTENZIONE: Inserisci i dati correttamente.");
                        tpl.process("home", datamodel, out);
                        out.close();
                        return;
                    }
                }

            } else {

                datamodel.put("errore", "ATTENZIONE: Inserisci i dati correttamente.");
                tpl.process("home", datamodel, out);
                out.close();
                return;
            }

        } else {

            datamodel.put("errore", "ATTENZIONE: Inserisci i dati d'accesso correttamente.");
            tpl.process("home", datamodel, out);
            out.close();
            return;
        }

    }

    // <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code.">
    /** Handles the HTTP <code>GET</code> method.
     * @param request servlet request
     * @param response servlet response
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        processRequest(request, response);
    }

    /** Handles the HTTP <code>POST</code> method.
     * @param request servlet request
     * @param response servlet response
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        processRequest(request, response);
    }

    /** Returns a short description of the servlet.
     */
    public String getServletInfo() {
        return "Short description";
    }
    // </editor-fold>
}
